home *** CD-ROM | disk | FTP | other *** search
/ Reverse Code Engineering RCE CD +sandman 2000 / ReverseCodeEngineeringRceCdsandman2000.iso / RCE / Ebooks / Thinking in Java / c10 / MakeDirectories.java < prev    next >
Encoding:
Java Source  |  2000-05-25  |  4.2 KB  |  116 lines

  1. //: MakeDirectories.java
  2. //////////////////////////////////////////////////
  3. // Copyright (c) Bruce Eckel, 1998
  4. // Source code file from the book "Thinking in Java"
  5. // All rights reserved EXCEPT as allowed by the
  6. // following statements: You can freely use this file
  7. // for your own work (personal or commercial),
  8. // including modifications and distribution in
  9. // executable form only. Permission is granted to use
  10. // this file in classroom situations, including its
  11. // use in presentation materials, as long as the book
  12. // "Thinking in Java" is cited as the source. 
  13. // Except in classroom situations, you cannot copy
  14. // and distribute this code; instead, the sole
  15. // distribution point is http://www.BruceEckel.com 
  16. // (and official mirror sites) where it is
  17. // freely available. You cannot remove this
  18. // copyright and notice. You cannot distribute
  19. // modified versions of the source code in this
  20. // package. You cannot use this file in printed
  21. // media without the express permission of the
  22. // author. Bruce Eckel makes no representation about
  23. // the suitability of this software for any purpose.
  24. // It is provided "as is" without express or implied
  25. // warranty of any kind, including any implied
  26. // warranty of merchantability, fitness for a
  27. // particular purpose or non-infringement. The entire
  28. // risk as to the quality and performance of the
  29. // software is with you. Bruce Eckel and the
  30. // publisher shall not be liable for any damages
  31. // suffered by you or any third party as a result of
  32. // using or distributing software. In no event will
  33. // Bruce Eckel or the publisher be liable for any
  34. // lost revenue, profit, or data, or for direct,
  35. // indirect, special, consequential, incidental, or
  36. // punitive damages, however caused and regardless of
  37. // the theory of liability, arising out of the use of
  38. // or inability to use software, even if Bruce Eckel
  39. // and the publisher have been advised of the
  40. // possibility of such damages. Should the software
  41. // prove defective, you assume the cost of all
  42. // necessary servicing, repair, or correction. If you
  43. // think you've found an error, please email all
  44. // modified files with clearly commented changes to:
  45. // Bruce@EckelObjects.com. (Please use the same
  46. // address for non-code errors found in the book.)
  47. /////////////////////////////////////////////////
  48.  
  49. // Demonstrates the use of the File class to
  50. // create directories and manipulate files.
  51. import java.io.*;
  52.  
  53. public class MakeDirectories {
  54.   private final static String usage =
  55.     "Usage:MakeDirectories path1 ...\n" +
  56.     "Creates each path\n" +
  57.     "Usage:MakeDirectories -d path1 ...\n" +
  58.     "Deletes each path\n" +
  59.     "Usage:MakeDirectories -r path1 path2\n" +
  60.     "Renames from path1 to path2\n";
  61.   private static void usage() {
  62.     System.err.println(usage);
  63.     System.exit(1);
  64.   }
  65.   private static void fileData(File f) {
  66.     System.out.println(
  67.       "Absolute path: " + f.getAbsolutePath() +
  68.       "\n Can read: " + f.canRead() +
  69.       "\n Can write: " + f.canWrite() +
  70.       "\n getName: " + f.getName() +
  71.       "\n getParent: " + f.getParent() +
  72.       "\n getPath: " + f.getPath() +
  73.       "\n length: " + f.length() +
  74.       "\n lastModified: " + f.lastModified());
  75.     if(f.isFile())
  76.       System.out.println("it's a file");
  77.     else if(f.isDirectory())
  78.       System.out.println("it's a directory");
  79.   }
  80.   public static void main(String[] args) {
  81.     if(args.length < 1) usage();
  82.     if(args[0].equals("-r")) {
  83.       if(args.length != 3) usage();
  84.       File 
  85.         old = new File(args[1]),
  86.         rname = new File(args[2]);
  87.       old.renameTo(rname);
  88.       fileData(old);
  89.       fileData(rname);
  90.       return; // Exit main
  91.     }
  92.     int count = 0;
  93.     boolean del = false;
  94.     if(args[0].equals("-d")) {
  95.       count++;
  96.       del = true;
  97.     }
  98.     for( ; count < args.length; count++) {
  99.       File f = new File(args[count]);
  100.       if(f.exists()) {
  101.         System.out.println(f + " exists");
  102.         if(del) {
  103.           System.out.println("deleting..." + f);
  104.           f.delete();
  105.         }
  106.       } 
  107.       else { // Doesn't exist
  108.         if(!del) {
  109.           f.mkdirs();
  110.           System.out.println("created " + f);
  111.         }
  112.       }
  113.       fileData(f);
  114.     }  
  115.   }
  116. } ///:~